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Limitation of Warranty 


This Hewlett-Packard product has a warranty against defects in material 
and workmanship for a period of three years from date of shipment. 
During warranty period, Hewlett-Packard Company will, at its option, 
either repair or replace products that prove to be defective. 

For warranty service or repair, this product must be returned to a service 
facility designated by Hewlett-Packard. However, warranty service for 
products installed by Hewlett-Packard and certain other products 
designated by Hewlett-Packard will be performed at the Buyer’s facility at 
no charge within the Hewlett-Packard service travel area. Outside 
Hewlett-Packard service travel areas, warranty service will be performed 
at the Buyer’s facility only upon Hewlett-Packard’s prior agreement and 
the Buyer shall pay Hewlett-Packard’s round trip travel expenses. 

For products returned to Hewlett-Packard for warranty service, the Buyer 
shall prepay shipping charges to Hewlett-Packard and Hewlett-Packard 
shall pay shipping charges to return the product to the Buyer. However, 
the Buyer shall pay all shipping charges, duties, and taxes for products 
returned to Hewlett-Packard from another country. 

Hewlett-Packard warrants that its software and firmware designated by 
Hewlett-Packard for use with an instrument will execute its programming 
instructions when properly installed on that instrument. Hewlett-Packard 
does not warrant that the operation of the instrument software, or 
firmware will be uninterrupted or error fi-ee. 

The foregoing warranty shall not apply to defects resulting from improper 
or inadequate maintenance by the Buyer, Buyer-supplied software or 
interfacing, unauthorized modification or misuse, operation outside of the 
environmental specifications for the product, or improper site preparation 
or maintenance. 

NO OTHER WARRANTY IS EXPRESSED OR IMPLIED. 
HEWLETT-PACKARD SPECEFICALLY DISCLAIMS THE 
IMPLIED WARRANTIES OR MERCHANTABIUTY AND FITNESS 
FOR A PARTICULAR PURPOSE. 


Exclusive Remedies 


Assistance 


Certification 


Safety 


THE REMEDIES PROVIDED HEREIN ARE THE BUYER’S SOLE 
AND EXCLUSIVE REMEDIES. HEWLETT-PACKARD SHALL 
NOT BE LIABLE FOR ANY DIRECT, INDIRECT, SPECIAL 
INCIDENTAL, OR CONSEQUENTIAL DAMAGES, WHETHER 
BASED ON CONTRACT, TORT, OR ANY OTHER LEGAL 
THEORY. 


Product maintenance agreements and other customer assistance 
agreements are available for Hewlett-Packard products. 

For any assistance, contact your nearest Hewlett-Packard Sales and 
Service Office. 


Hewlett-Packard Company certifies that this product met its published 
specifications at the time of shipment from the factory. Hewlett-Packard 
further certifies that its calibration measurements are traceable to the 
United States National Bureau of Standards, to the extent allowed by the 
Bureau’s calibration facility, and to the calibration facilities of other 
International Standards Organization members. 

This product has been designed and tested according to International 
Safety Requirements. To ensure safe operation and to keep the product 
safe, the ii^ormation, cautions, and warnings in this manual must be 
heeded. 
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Introduction This manual, combined with the HP 1650QA Programming Reference 

manual, provides you with the information needed to program the 
HP 16515A/16516A1 GHz Timing Analyzer module. Each module has 
its own programming manual to supplement the mainframe manual since 
not all mainframes will be configured with the same modules. 



About This 
Book 


This manual is organized into five chapters. The first chapter contains: 


• General information and instructions to help you get started 

• Mainframe system commands that are frequently used with the 
1 GHz timing analyzer module 

• The HP 16515A/16516A1 GHz Timing Analyzer command tree 

• Alphabetic command-to-subsystem directory 


Chapters two through five contain all the subsystem commands for the 
HP 16515A/16516A1 GHz Timing Analyzer. 

Appendix A contains information on the SYSTem:DATA and 
SYSTem:SETup commands for this module. 

Error messages for the HP 16515A/16516A1 GHz Timing Analyzer are 
included in the system error messages in Appendix C of the HP 1650QA 
Programming R^erence manual. 
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Programming 
the 1 GHz 
Timing Anaiyzer 


This section introduces you to the basic command structure used to 
program the 1 GHz timing analyzer. Also included is an example 
program that sets up the timing analyzer for a measurement. 


Selecting the Module Before you can program the 1 GHz timing analyzer, you must first ’’select 

it. This directs your commands to the appropriate module. 


To select the module, use the mainframe command rSELect followed by 
the numeric reference for the slot location of the master card for the 1 
GHz timing analyzer (1...5 corresponds to slot A...E respectively). For 
example, if the master card for your 1 GHz timing analyzer is in slot B, 
then the command: 


:SELECT 2 


would select this module. For more information on the select command, 
refer to the HP 16500A Programming Reference manual. 

Programming the A typical 1 GHz timing analyzer program would: 

Anaiyzer 

• select the appropriate module 

• assign labels 

• set pod thresholds 

• specify a trigger condition 

• set up the display 

• specify the acquisition type 

• start the acquisition 
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The following example program sets up the timing analyzer to make a 
simple measurement. 

Example Program: io output xxx;“:SELECT 4" 

20 OUTPUT XXX;“:FORMAT:LABEL ’A’.POS.r 
30 OUTPUT XXX;*:FORMAT:LABEL ’B’.POS^a** 

40 OUTPUT XXX;“:FORMAT:THRESHOLD2 TTL" 

50 OUTPUT XXX;“:TRACE:MATCH EQUAL- 
60 OUTPUTXXX;-:TRACE:PATTERN‘A’,'#B0’" 

70 OUTPUT XXX;'‘:TRACE:PATTERN 
80 OUTPUT XXX;-:TRACE: DURATION GT, 35ns- 
90 OUTPUT XXX;-:TRACE:EDGE ’A’.X- 
100 OUTPUT XXX;":TRACE:EDGE ’B’/P- 
110 OUTPUT XXX;-:RMODE SINGLE- 
120 OUTPUT XXX;-:START" 

130 OUTPUT XXX;":MENU 4.2" 

140 END 


Note 

The three Xs (XXX) ctfier the ""OUTPUT statements in the 
previous examples refer to the device address required for 
programming over either HP-IB or RS-232C. Refer to your 
controller manual and programming language reference manual 
for information on initializing the interface. 
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Program Comments Line 10 selects the 1 GHz timing analyzer in slot D. 

Line 20 assigns channel 0 of pod D2 (master card pod 2) to the label "A” 
and assigns a positive polarity to this label. 

Line 30 assigns channel 1 of pod D2 to the label ”6'' and assigns a positive 
polarity to this label. 

Line 40 sets the threshold level for pod D2 to TTL. 
lines 50 to 100 configures the analyzer to find the pattern where both the 
signal for label is low and the signal for label is high for 
greater>than 35 ns. When it finds this pattern^ the analyzer will trigger on 
the falling edge of the signal on label ’’B.” 

Lines 110 and 120 tell the analyzer to run the measurement one time. 
Line 130 displays the 1 GHz timing analyzer’s Waveforms menu so you 
can view the results of your measurement. 

For more information on the specific 1 GHz timing analyzer commands, 
refer to chapters 2 through 5 of this manual. 
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Mainframe 

Commands 

CARDcage? 

Query 


Example: 


These commands are part of the HP 16500A mainframe system and are 
mentioned here only for reference. For more information on these 
commands refer to the HP 16S00A Programming Reference manual. 

The CARDcage query returns a series of integers which identifies the 
modules that are installed in the mainframe. The returned string is in two 
parts. The furst five numbers returned identify the card type. The 
identification number for the HP 16515A master card is 1 and the 
identification number for the HP 16516A expansion card is 2. A ”-1" in 
the first part of the string indicates that no card is installed in the slot. 

The five numbers in the second part of the string indicate which slots have 
cards installed, which card has the controller software for the module, and 
where the master card is located. 

-1,-1,2,1,31,0,0,4,4,5 

The first five numbers in the string shown in the example indicate that no 
cards are installed in slot A and B. An HP 16516A expansion card (ID 
number 2) is loaded in slot C and an HP 16S15A master card (ID number 
1) is loaded into slot D. Slot E contains an HP 16510A logic analyzer (ID 
number 31). 

The last five numbers (0,0,4,44) indicate that a two card module is located 
in slots C and D with the master card in slot D. Also, a single module 
card is located in slot £. The ”0” indicates that no card is installed in slot 
A or B or the module software is not recognized or not loaded. For more 
information on the CARDcage query, refer to the 
HP 16500A Programming Reference manual. 
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MENU The MENU command selects which menu will be displayed. The first 
Command/query parameter specifies the desired module. The optional second parameter 

specifies the desired menu in the module (defaults to 0 if not specified). 
The query returns the currently displayed menu. 

For the HP 16515A/16516A1 GHz Timing Analyzer: 

• MENUX,0 - Format menu 

• MENUX,! - Trace menu 

• MENUX,2 - Waveforms menu 


Where X refers to the slot where the master card for this module is 
installed. 

RMODe The RMODe command specifies the run mode (single or repetitive) for a 
Command/query module or intermodule. If the selected module is in the intermodule 

configuration, the intermodule run mode will be set by this command. 

The RMODe query returns the current setting. 

SELect The SELect command selects which module (or intermodule) will have 
Command/query parser control. SELECT 0 selects intermodule, SELECT 1 through S 

selects modules A through E respectively. The values -1 and -2 select 
software options 1 and 2. The SELect query returns the value for the 
currently selected module. 

STARt The STARt command starts the selected module or intermodule running. 
Command If the specified module is in the intermodule configuration, the STARt 

command will start all of the modules in the intermodule configuration 
running. 

STOP The STOP command stops the selected module or intermodule. If the 
Command specified module is in the intermodule configuration, the STOP command 

will stop all of the modules in the intermodule configuration. 
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Note 


SYSTemrERRor? 

Query 


SYSTemrPRINt 

Command/query 


MMEMory 

Subsystem 

INTermodule 

Subsystem 


The STARt and STOP commands are Overlapped Commands. 
An Overlapped Command is a command that allows execution 
of subsequent commands while the device operations initiated by 
the Overlapped Command are still in progress. For more 
information, refer to the *OPC and *WAI commands in the HP 
1650QA Programming R^erence manual. 


The SYSTem:ERRor query returns the oldest error in the error queue. 

In order to return all of the errors in the error queue, a simple 
FOR/NEXT loop can be written to query the queue until all of the errors 
are returned. When all of the errors are returned, the query returns zeros. 

For a complete list of error messages, refer to the HP 16500A 
Programming Reference manual. 

The SYSTemiPRINt command initiates a print of the screen or listing 
buffer over the current printer communication interface. The 
SYSTemiPRINt query sends the screen or listing buffer data over the 
current controller communication interface. 

The MMEMory subsystem provides access to both internal disc drives for 
loading and storing configurations. 

The INTermodule subsystem commands are used to specify intermodule 
arming between multiple modules. 
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Command Set 
Organization 


The command set for the HP 16515A/16516A is divided into four separate 
groups. Each of these groups of commands is described in the following 
chapters. 


Each of the chapters contain a brief description of the subsystem, syntax 
diagrams, and the commands for that subsystem in alphabetical order. 
The commands are shown in longform andshortform using upper and 
lowercase letters. For example, LABel indicates that the longform of the 
command is LABEL and the shortform of the command is LAB. Each of 
the commands contain a description of the command and its arguments, 
the command syntax, and a programming example. 

Figure 1*1 is a command tree that summarizes of all of the commands for 
the HP 16515A/16516A1 GHz Timing Analyzer module. The (x) in the 
command tree figure represents the slot number in which the master card 
for the 1 GHz timing analyzer module is located. 


where: 


SELect 0 = System 
SELect 1 = Slot A 
SELect 2 = Slot B 
SELect 3 = Slot C 
SELect 4 = Slot D 
SELect 5 = Slot E 


Table 1-1 is an alphabetical command to subsystem directory. 
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FORMat 


TRACc 


WAVeform 


SYMBol 


LABel DURation Accumulate BASE 

REMcjvc EDGE DELay PATTcm 

THReshold MATCh INSert RANGe 

PATTcm MINUS REMovc 

MMODe WIDTh 

OCONdition 

OPATtcm 

OSEarch 

OTIMe 

OVERlay 

PLUS 

RANGe 

REMove 

RUNTil 

SPERiod 

TAVcrage 

IMAXimum 

TMINimum 

VRUNs 

XCONdition 

XOTime 

XPATtem 

XSEarch 

XTIMc 


Figure M. HP 16515AI16516A Command Tree 
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Table 1-1. Alphabetic Command Cross-Reference 


Command 

Where Used 

Command 

Where Used 

Accumulate 

Waveform Subitem 

RANGe 

Waveform Subitem 

BASE 

Symbol Subsystem 

REMove 

Format Subitem 

DELay 

Waveform Subsystem 

REMove 

Symbol Subitem 

DURation 

Trace Subsystem 

REMove 

Waveform Subitem 

EDGE 

Trace Subsystem 

RUNTil 

Waveform Subitem 

FORMat 

Subsystem Selector 

SPERiod 

Waveform Subitem 

INSert 

Waveform Subsystem 

SYMBol 

Subsystem Selector 

LABel 

Format Subitem 

TAVerage 

Waveform Subitem 

MATCH 

Trace Subsystem 

THReshold 

Format Subsystem 

MINUS 

Waveform Subsystem 

TMAXimum 

Waveform Subi^tem 

MMODe 

Waveform Subsystem 

TMINimum 

Waveform Subitem 

OCONdition 

Waveform Subitem 

TRACe 

Subsystem Selector 

OPATtem 

Waveform Subitem 

VRUNs 

Waveform Subitem 

OSEarch 

Waveform Subsystem 

WAVeform 

Subsystem Selector 

OITMe 

Waveform Subitem 

WIDTH 

Symbol Subitem 

OVERlay 

Waveform Subitem 

XCONdition 

Waveform Subitem 

PATTem 

Symbol Subsystem 

XOTime 

Waveform Subitem 

PATTcm 

Trace Subsystem 

XPATtern 

Waveform Subitem 

PLUS 

Waveform Subsystem 

XSEarcH 

Waveform Subitem 

RANGe 

Symbol Subitem 

XITMe 

Waveform Subsystem 


Prc^ramming the HP 16515A/16A 
1-10 











Module Status 
Reporting 


Each module reports its status to the Module Event Status Register 
(MESR) which in turn reports to the Combined Event Status Register 
(CESR) in the HP 16500A mainframe (see chapter 6 of the HP 1650QA 
Programming Reference manual). The Module Event Status Register is 
enabled by the Module Event Status Enable register (MESE). 

The following descriptions of the MESE and MESR commands provide 
the module specific information required to enable and interpret the 
contents of the registers. 



1B500/BL23 


Modu ! e 


^ Mainframe 


Figure 1-2. Module Status Reporting 
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MESE 


MESE command/query 

The MESE command sets the Module Event Status Enable register bits. 
The MESE register contains a mask value for the bits enabled in the 
MESR register. A one in the MESE register will enable the 
corresponding bit in the MESR. A zero will disable the bit. 

The first parameter specifies the module, and the second parameter 
specifies the enable value. 1...5 corresponds to the module in slot A...E. 

The MESE query returns the current setting. 

Refer to table 1-2 for information about the Module Event Status Enable 
register bits, bit weights, and what each bit masks for this modxile. For 
more information on status reporting refer to the HP 1650QA 
Programming Reference manual. 

Command Syntax: :MESE<N> <enable.mask> 

where: 

<N> {1|2|3|4|5} number of slot in which the moduie resides 

< enabie^mask > = 0 to 65535 finteger) 


Example: output XXX;'‘:MESE4 2 - 
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MESE 


Query Syntax: :MESE<n>? 

Returned Format: [:MESE<N>] <enable_mask><NL> 

Example: io dim Mese$[ioo] 

20 OUTPUT XXX;“:MESE47" 

30 ENTER XXX; Mese$ 

40 PRINT Mese$ 

50 END 

Table 1-2, HP 1651SA/16516A Module Event Status Enable Register 


Bit 

Wei^t 

Enables 

7 

128 

not used 

6 

64 

not used 

5 

32 

not used 

4 

16 

not used 

3 

8 

not used 

2 

4 

TRG - Trigger Received 

1 

2 

RNT - Run Until Satisfied 

0 

1 

MC - Measurement Complete 


The Module Event Status Enable Register contains a mask value for the 
bits to be enabled in the Module Event Status Register (MESR). A one in 
the MESE enables the corresponding bit in the MESR, a zero disables the 
bit. 
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MESR 



MESR 


query 


The MESR query returns the current contents of the Module Event 
Status register. 


Note 

Reading the re^ster clears the bits of the Module Event Status 
Renter. 

Table 1-3 shows each bit in the Module Event Status Register and their bit 
weights for this module. When you read the MESR, the value returned is 
the total bit weights of all bits that are high at the time the register is read. 

The parameter specifies the module. 1...5 corresponds to the module in 
slot A...E respectively. 

Query Syntax: :MESR<n>? 

Returned Format: [:MESR<n>] <status> <nl> 


where: 

<N> {11213|4|5} number of slot in which the module resides 

< status > :: 0 to 65535 (integer) 


Example: io dim Mesr$[ioo] 

20 OUTPUT XXX;":MESR5?” 
30 ENTER XXX; Mesr$ 

40 PRINT Mesr$ 

50 END 
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MESR 


Table 1-3, HP 16515AI16516A Module Event Status Register 


Bit 

Bit 

Weight 

Bit 

Name 

Condition 

7 

128 


0 = not used 

6 

64 


0 = not used 

5 

32 


0 = not used 

4 

16 


0 = not used 

3 

8 


0 = not used 

2 

4 

TRG 

0 = Trigger Not Received 

1 = Trigger Received 

1 

2 

RNT 

0 - Run Until Not Satisfied 

1 = Run Until Satisfied 

0 

1 

MC 

0 = Measurement Not Complete 

1 = Measurement Complete 
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FORMat Subsystem 




introduction The FORMat subsystem commands allow you to configure the Format 

menu of the 1 GHz timing analyzer. These commands specify how the 
analyzer is connected to the system under test. This includes renaming 
labels, assigning polarity, grouping channels into different labels, and 
setting the sampling threshold voltages for each pod. Figure 2-1 shows the 
syntax diagram for these conunands. 
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assign == integer, 0 to 255. 

index = integer, 1 to 4. 

value = real number, -3.5 to +5.ft 

Figure 2-1. Format Subsystem Commands Syntax Diagram 
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LABel 


LABel command/query 

The LABel command allows you to specify polarity, create labels, and 
assign channels to new or existing labels. If the specified label name does 
not match an existing label name, a new label will be created. 

The pod order and assignment (number) is significant since each 
assignment parameter refers to a separate pod. The first two assignment 
parameters are for pods 2 and 1 (respectively) of the HP 16515A master 
card. The last two assignment parameters are for pods 2 and 1 
(respectively) of the HP 16516A expansion card. When the assignment 
value is expressed in binary (base 2), each bit of the value represents one 
of the channels of the associated pod. Bit 0 represents channel 0, bit 1 
represents channel 1, bit 2 represents channel 2, etc. A ”1” in a bit 
position means the associated channel in the pod is assigned to the label. 

A "0” in the bit position means the associated channel in the pod is 
excluded from the label. If an assignment value is not specified, no 
channels are assigned to the label. 

The LABel query returns the current settings for the specified label. If 
the label does not exist, no value is returned. 

Command Syntax: :FORMat:LABel <label_nanne>[,{positive|NEGative}],<assign>[,<assign>,...] 

where: 

< iabel_name > « string of up to 6 alphanumeric characters 

< assign > 0 through 255 finteger) 

Examples: The following example assigns bits 1 and 0 of pod 2 and bit 1 of pod 1 to 

the label A with a positive polarity.. 

OUTPUT XXX;-:FORMAT:LABEL ’A’.POSmVE, 3,2" 
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LABel 



The following example assigns bits 1 and 0 of pod 1 to the label CAS. 
OUTPUT XXX:":FORM;LAB ’CAS’.0,3" 


Query Syntax: : PORMat LABel? < label_name > 

Returned Format: [;FORMat:LABei] 

< iabel_neune > .{POSitive | NEGative}, < assign > [, < assign >...]< NL> 


Example: 10 OiM Setting$[100] 

20 OUTPUT XXX:“:FORM:LABEL? ’A’" 
30 ENTER XXX;Setting$ 

40 PRINT Settings 
50 END 
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REMove 



REMove 


command 


The REMove command either deletes all the labels or a specified label 
from the Format menu. 

Command Syntax: ;FORMat;REMove {AU.| <label_name>} 

Where: 

< label_name > = string of up to 6 alphanumeric characters 


Examples: output xxx-":FORMAT:REMOVE all" 

OUTPUT XXX;":FORM:REM ’A’" 
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THReshold 


THReshold command/query 

The THReshold cx)mmaiid specifies a threshold level for a particular 
1 GHz timing analyzer pod. The < N > parameter is an index which 
specifies which pod you want to set the threshold on. A1 or 2 refers to 
the HP 16515A master card pods 1 and 2 respectively. A 3 or 4 refers to 
the HP 16516A expansion card pods 1 and 2 respectively. The threshold 
can be set to standard TTL or ECL levels, or a specific voltage between 
+ 5.0 and -3.5 volts in 0.1 volt increments. 

The THReshold query returns the specified pod’s current threshold 
setting. 

Command Syntax: :FORMat:THReshold < N > {TTL| ECL| < value > } 

where: 

<N> 1 through 4 (integer) 

< value > = voltage -3.5 to +5.0 (real number) 

TTL :: = default value of +1.5 V 
ECL :: ~ default value of -1.3 V 

Examples: output XXX;":F0RMAT;THRESH0LD2 TTL" 

OUTPUT XXX:":FORMAT:THRESHOLD2 -3.5V" 
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THReshold 


Query Syntax: :FORMat:THReshoid<N>7 

Returned Format; [:FORMat:THReshold<N>] {TTL|ECL|<value>><NL> 

Example; 1 o dim Setting$[i oo] 

20 OUTPUT XXX;":FORMAT:THR2?" 

30 ENTER XXX;Setting$ 

40 PRINT Settings 
50 END 
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TRACe Subsystem 



Introduction The TRACe subsystem contains the commands available for configuring 

the Trace menu of the 1 GHz timing analyzer. These commands are used 
to specify the trigger point for the analyzer. This includes specifying 
patterns, edges, and pattern durations. Figure 3>1 shows the syntax 
diagram for these commands. 



Figure 3-1. Trace Subsystem Commands Syntax Diagram 
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duration_vaIue = real number. 

label_name = string of up to 6 alphanumeric characters. 

edge_spec = {/?|/'|^. 

pattern = stringinoneof the following forms: 

"#BOnr for binary 

”#Q01234567r for octal 

''*H0123456789ABCDEFX'for hexadecimal 

”0123456789” for decimal 

(don’t cares ”X” not allowed in decimal) 

Figure 3-1. Trace Subsystem Commands Syntax Diagram (Continued) 
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DURation 



DU Ration 


command/query 


The DURation command specifies the amoimt of time the specified 
pattern must be valid. The first parameter specifies whether the pattern 
must be valid for Greater-Than (GT) or Less-Than (LT) the specified 
duration. The second parameter specifies the duration value. The 
DURation query returns the current pattern duration setting. 

Note 

The values for pattern duration follow a preset sequence which 
varies depending on the current sample rate and duration mode 
(less-than or p'eater-thanf To view the value for your current 
configuration, enter the value you want with the DURation 
command. Then send the DURation query to view the actual 
displayed value. 


If a pattern is specified across boards (HP 1651SAI16516A), 
less~than (LT) duration is no longer available. 


Command Syntax: :TRACe:DURation {LT|GT},<duration.vaiue> 


where: 


GT 

LT 

< duration value > 


- greater than 

- less than 

» real number 


Example: output XXX-^TRACEDURATION LT.IOns* 
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DURation 


Query Syntax: :TRACe:DURation7 

Returned Syntax: [TRACe:DURation] {LT|GT},<duration_value> <NL> 

Example; 10 dim Setting$[1 OO] 

20 OUTPUT XXX,":TRACE:DURATION?" 

30 ENTER XXX: Settings 
40 PRINT Settings 
50 END 
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EDGE 


EDGE command/query 

The EDGE command specifies the edge patterns for the 1 GHz timing 
analyzer to trigger on. Each command deals with only one label. 

Therefore, an edge specification over multiple labels will require multiple 
commands. The first parameter specifies the label and the second 
parameter specifies the edge specification for the given label. The edge 
specification uses the characters R, F, and X to indicate the edges or don’t 
cares as follows: 

• ”R" - Rising edge 

• "P - Falling edge 

• "X” - don’t care (ignore the channel) 

The position of these characters in the string correspond with the position 
of the channels in the label. All channels without Xs are ORed together 
to form the edge specification. The EDGE query returns the current 
edge specification for the specified label. 

Command Syntax: :TRACe:EDGE <label_name>,<edge_spec> 

where: 

< label_name > ~ string of up to 6 alphanumeric characters 

< edge_spec > :: = string of characters {R | F |X} 

Example: output XXX;":TRACE:EDGE ’A’.’XRFXXXRFXXX’" 

Note 

The < edge_spec > must contain precisely the same number of 
characters as there are channels in specified label 
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EDGE 



Query Syntax: :TRACe:EDGE? < labeLname > 


Returned Format: [:TRACe:EDGE] <label^name>,<edge^spec><NL> 

Example: 10 dim Pattern$[100] 

20 OUTPUT XXX;“:TRACE:EDGE? ’A’" 

30 ENTER XXX;Pattern$ 

40 PRINT Patterns 
50 END 
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MATCh 


command/query 


The MATCh command specifies whether the analyzer will trigger on a 
pattern equal (or not equal) to the pattern spedfied in the Trace menu. 
The MATCh query returns the current setting. 

Note 

Selecting NEQual (not equal) with the MATCh command forces 
the duration setting to Greater-Than (GT). 


Command Syntax: 
Example: 
Query Syntax: 
Returned Format: 


;TRACe:MATCh {EQUalj NEQual} 
OUTPUT XXX:“:TRACE:MATCH EQUAL* 
:TRACe: MATCh? 

[:TRACe:MATCh] {EQUal| NEQual} <NL> 


Example: 10 dim Setting$[100] 

20 OUTPUT XXX;":TRACE:MATCH?" 
30 ENTER XXX;Setting$ 

40 PRINT Settings 
50 END 
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PATTern 


PATTern command/query 


The PATTem command specifies trace patterns for the 1 GHz timing 
analyzer. The first parameter specifies the label and the second 
parameter specifies the pattern for the label. Since each command deals 
with only one label, a complete pattern specification over multiple labels 
will require multiple commands. Each label can contain up to 32 bits with 
a range between 0 and FTTTTTTFF hexadecimal. Since a pattern can 
contain don't cares (X) and be represented in several bases, the pattern 
specification parameter is handled as a string of characters. 

Note 

If a pattern is specified across boards (HP 16515AI16516A), 
less-than (LT) duration is no longer available. 

The PATTem query returns the current pattern for the spedfied label in 
the base defined for the label. 


Note 

If negative polarity has been specified by the LABel command 
(see the LABel command in the chapter ""Format Subsystem""), a 
1 bit in a pattern specifies a level below threshold at the pod and 
a 0 bit specifies a level above threshold at the pod. 


Command Syntax: :TRACe:PATTern <iabel_name>,<pattern> 

where: 

< iabei.name > ~ string of up to 6 alphanumeric characters 

< pattern > - string in one of the following forms: 

•'#B01X" for binary 
'•#Q01234567X" for octal 
"#H0123456789ABCDEFX" for hexadecimal 
-0123456789-for decimal 
(don't cares -X" not allowed in decimal) 
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PATTern 



Example: 
Query Syntax: 
Returned Format: 


OUTPUT XXX;":TRACE:PATTERN •A’.'#BO1X0OXO1'“ 
;TRACe:PATTern? < label name> 


[:TRACe:PATTern] <led3el_name>,<pattern> <NL> 


Example: io dim Pattem$[ioo] 

20 OUTPUT XXX;":TRACE: PATTERN? ’A" 
30 ENTER XXX; Patterns 
40 PRINT Patterns 
50 END 
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WAVeform Subsystem 


4 


i ntrOdUCtion The WAVeform subsystem contains all of the commands available for the 

HP 16515A/16516A Waveforms menu. These include commands for 
setting up the waveform display and making marker measurements. 

Figure 4-1 shows the syntax diagram for these commands. 



Figure 4-2. Waveform Subsystem Commands Syntax Diagram 
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d_value = real number, -1Z5 s to 53.5E3 s. 
module_spec = integer, 1 to 5. 
iabel_name = string of up to 6 alphanumeric characters. 
bit_no = integer, 0to 31. 

waveform = string cfone alpha and one numeric character. 
pattern = string in one of the following forms: 

”#B0Ur for binary 
''#Q01234567r for octal 
''#H0123456789ABCDEFX” for hexadecimal 
”0123456789" for decimal 
(don’t cares ”X" not allowed in decimal) 
occurrence = integer, -8192 to 8192. 
time = real number, -13.0 s to 53.5E3s. 
r_value = real number, 10E-9sto 10 s. 
value = real mtmber, -53.5E3 s to 53.5E3 s. 

Figure 4-1. Wav^orm Subsystem Commands Syntax Durham (Contitmed) 
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Accumulate 


command/query 


The Accumulate command controls whether the waveform display gets 
erased between individual runs or whether it accumulates. The 
Accumulate query returns the current setting. 

Command Syntax: :WAVeform;ACCumulate {{ON11} I{OFF|0}} 

Example: output XXX;*:WAVEF0RM:ACCUMULATE ON" 

Query Syntax: :WAVeform:ACCumulate7 
Returned Format: [;WAVeform:ACCumulate] {01 1 } < NL > 


Example: 10 dim Setting$[100] 

20 OUTPUT XXX;*:WAVEFORM:ACC?" 
30 ENTER XXX;Setting$ 

40 PRINT Settings 
50 END 
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DELay 


DELay 


command/query 


The DELay command spedfies the amount of time between the timing 
trigger and the horizontd center of the screen in the waveforms display. 
The allowable values for delay are -12.5 s to -l- 53.5 ks. The DELay query 
returns the current offset value (delay) from the trigger. 


Command Syntax: 

:WAVeform: DELay < d_value > 

where: 


< devalue > 

:: = -12.5 s to +53.5E3 s (real number) 

Example: 

OUTPUT XXX;'‘:WAVEFORM:DELAY 400E-9' 

Query Syntax: 

:WAVeform: DELay? 

Returned Format: 

[:WAVeform:DELay] <devalue><NL> 

Example: 

10 DIM Delay_value$[100] 


20 OUTPUT XXX:":WAVEFORM:DELAY?" 
30 ENTER XXX;Delay_value$ 

40 PRINT Delay_yalue$ 

50 END 
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INSert 


iNSert command 


The INSert command inserts time correlated waveforms in the waveform 
display. The waveforms are added directly below the last waveform on 
screen. When the maximiim number of waveforms are present on screen 
(24), inserting an additional waveform replaces the last waveform on 
screen. 

Time correlated waveforms from the oscilloscope and other timing 
analyzers in the HP 16500A system can also be inserted in the 1 GHz 
timing analyzer’s display. When inserting waveforms from the 
oscilloscope or other timing analyzer modules, the optional first 
parameter must be used. 1...5 corresponds to the modules in slot A...E. If 
the module specifier is not selected, the currently selected module is 
assumed. 

The second parameter specifies the label for the waveforms to be added. 

The optional third parameter specifies the label bit number, OVERlay, or 
ALL. If a number is specified, only the waveform for that bit nmnber is 
added to the screen. 

If O VERlay is specified, all the bits of the label are displayed as a 
composite overlayed waveform. If ALL is specified, all the bits of the 
label are displayed sequentially. If the third parameter is not specified, 
ALL is assumed. 
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INSert 


To insert a waveform from another timing analyzer to the 1 GHz timing 
analyzer’s display: 

Command Syntax: ;WAVeform:INSert [ < module^spec >,] < labeLname > [,{ < blt_no > | OVERlay | ALL}] 

where: 

< module^speo :: = 1 through 5 fmteger) 

< iabei_name > ~ string of up to 6 alphanumeric characters 

< bit_no > :: = 0 through 31 (integer) 

Examples: output xxx;":waveform:insert 2 ,’A’,overlay- 

output XXX;-:WAV:INSERT W 

To insert a waveform from an oscilloscope module to the 1 GHz timing 
analyzer’s display: 

Command Syntax: :WAVeform;INSert <module_spec>,<waveform> 

where: 

< module^spec > = 1 through 5 for slot in which timebase card is Installed (integer) 

<waveform > :: = <acquisition^spec > {112} (string format) 

< acquisition^spec > - {A | B | C10} (slot where acquisition card is located) 

Example: output XXX;-: waveform: insert 4,‘Cl *" 
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MINUS command 


The MINUS command inserts time correlated A-B (A minus B) 
oscilloscope waveforms on the screen. The first parameter is the module 
specifier where 1..5 corresponds to the slot A...E in which the module is 
located. The next two parameters specify the oscilloscope waveforms to 
be subtracted fi-om each other. 

ComiTianci Syntax: :WAVeform: minus < module^spec >, < waveform >, <waveform > 

where: 

< module_spec > - i through 5 for slot in which oscilloscope timebase card is installed (integer) 

<waveform> <acquisitlon_spec>{112} 

< acquisltion^spec > - {A| B | C | D} (slot where acquisition card is located) 

Example: output XXX;": waveform.* minus 2 .’A 1 ’.’B 1 

Note 

This command is only available for oscilloscope waveforms 
from an oscilloscope module in the same mainframe. 
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MMODe command/query 

The MMODe (Marker Mode) command selects the mode for 
controlling marker movement and the display of marker readouts. When 
the marker mode is OFF, the markers do not appear on screen and the 
current sample period is displayed. When PAlTem is selected, the 
markers are placed on the specified patterns. When TIME is selected, the 
markers are positioned in time. In MSTats, the markers are placed on 
patterns, but the readouts will be time statistics. 

The MMODe query returns the current marker mode. 

Command Format: :WAVeform:MMODe {off|time|PATT ern|MSTats} 

Example: output XXX;":WAVEF0RM:MM0DE timp 
Query Syntax: :WAVeform:MMODe? 

Returned Format: [:WAVeform:MMODe] {0FF|TIMEIPATTern |MSTats}<NL> 

Example: 10 dim Setting$[100] 

20 OUTPUT XXX;*:WAVEFORM:MMODE?" 

30 ENTER XXX;Settlng$ 

40 PRINT Settings 
50 END 
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OCONdition 



command/query 


The OCONdition command specifies whether the marker is to be placed 
on the entry or exit point of the pattern when you are in the PATTem 
marker mode. The OCONdition query returns the current setting. 

Command Syntax: ;WAVeform:OCONclition {ENTering | EXITing} 

Example; output XXX;":WAV/EF0RM;0C0NDITI0N exiting* 

Query Syntax: :WAVeform:OCONdition7 

Returned Format: [:WAVeform;OCONdition] {ENTering I EXITing} 

Example: 10 dim Setting$[100] 

20 OUTPUT XXX;*:WAVEFORM:OCONDmON? 

30 ENTER XXX; Settings 
40 PRINT Settings 
50 END 
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OPATtern command/query 

The OPATtern command specifies a search pattern for the O marker 
which is then used with the OSEarch criteria and OCONdition for placing 
the marker on the pattern. The first parameter specifies the label and the 
second parameter specifies the search pattern for the label. Since each 
command deals with only one label, a specification over multiple labels 
requires multiple commands. 

Each label can contain up to 32 bits with a range between 0 and 
FFFFFFFFh (hexadecimal). Since the search pattern for the label can 
contain don’t cares (X) and be represented in several bases, the pattern 
specification parameter for the label is bandied as a string. 

In the PATTem marker mode, the OPATtern query returns the pattern 
specification for a given label. In the TIME marker mode, the query 
returns the pattern under the O marker for a given label. 

Command Syntax: :WAVeform:OPATtern < labei_name >, < pattern > 

where: 

< labei_name > :: ^ string of up to 6 alphanumeric characters 

< pattern > » string in one of the following forms: 

"#B01X" for binary 

"#CX)1234567X" for octal 

"#H0123456789ABCDEFX” for hexadecimal 

"0123456789" for decimal 

(doni cares "X" not allowed in decimal) 

Example: output XXX;":WAVEF0RM:0PATTERN ’A’,’#B01001XX01 1 
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Query Syntax: :WAVeform:OPATtern? <label_name> 

Returned Format: [:WAVeform:OPATtern] <label_name>,<pattern><NL> 

Example: 10 dim Pattern$[100] 

20 OUTPUT XXX;“:WAV:OPATTERN? ’A”' 

30 ENTER XXX; Patterns 
40 PRINT Patterns 
50 END 
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OSEarch 


command/query 


The OSEarch command specifies the search criteria for the O mEirker 
which is then used with the associated OPATtem specification and the 
OCONdition for placing markers on patterns. The first parameter 
determines which occurrence of the OPATtem specification, relative to 
the starting point, the marker actually searches for. An occurrence of 0 
(zero) places a marker on the selected starting point (trigger or X 
marker). The second parameter specifies whether the search will begin 
with the trigger or X marker. 

The OSEarch query returns the search criteria for the O marker. 

Command Syntax: :WAVeform:OSEarch < occurrence >[,{XMARker ITRiGger}] 

where: 

< occurrence > * -8192 to + 8192 Onteger) 


Example: output XXX;“:WAVEF0RM:0SEARCH 5 ,TRIGGER" 


Query Syntax: :WAVeform:OSEarch7 


Returned Format: [:WAVeform:OSEarch] < integer > .{XMARker | TRIGger} < NL> 


Example: 10 dim Settings 

20 OUTPUT XXX;":WAVEFORM:OSEARCH?- 
30 ENTER XXX; Settings 
40 PRINT Settings 
50 END 
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OTIMe 


OTIMe command/query 

The OTIMe command places the O marker at a specified position in time 
when the marker mode is TIME. 

The OTIMe query retimis the current position of the O marker. If there 
is no valid data, 9.9E37 is returned. 

Command Syntax: :WAVeform:OTiMe <time> 

where: 

<time > = -13.0 s to +53.5E3 s (real number) 

Example: output XXX;“:WAVEFORM:OTIME540ns“ 

Query Syntax: :WAVeform:OTIMe? 

Returned Format: [:WAVeform:OTIMe] <time > < NL> 

Example: io dim o_vaiue$[ioo] 

20 OUTPUT XXX;":WAVEFORM:OTIME?” 

30 ENTER XXX;0_value$ 

40 PRINT 0_value$ 

50 END 
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OVERlay command 

The OVERlay command adds time correlated overlayed oscilloscope 
waveforms to the screen. The first parameter is the module specifier. 1...S 
specifies the slot A...E where the module that has waveforms to be 
inserted is located. The next parameters specify the oscilloscope 
waveforms to be overlayed. 

Confimand Syntax: :WAVeform:OVERIay < module_8pec >, < waveform >,[ < waveform >...] 

where: 

< module^speo > - 1 through 5 for slot in which oscilloscope timebase card is installed (integer) 

< waveform > :: = < acqulsition_spec > {112} 

<acquicltion_spec > = {A| B | C | D} (slot where oscilloscope acquisition card is located) 

Example: output XXX;-:WAVEF0RM:0VERLAY 2,’A1 ’,'A2’" 
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PLUS 


command 


The PLUS command inserts time correlated A+B (A plus B) 
oscilloscope waveforms on the screen. The first parameter is the module 
specifier where 1...5 corresponds to the slot location A...E of the module 
that has waveforms to be inserted. The next two parameters specify which 
oscilloscope waveforms are to be added together. 

Command Syntax: :WAVeform :plus < module__spec >, <waveform >, <waveform > 


where: 


<module_spec> 
< waveform > 
< acquisition_spec > 


- 1 through 5 for slot in which oscilloscope timebase card is installed (integer) 

- < acquisltion^spec > {112} 

= {A IBICIDIE} (slot where oscilloscope acquisition card is iocated) 


Example: output XXX;":WAVEF0RM:PLUS 2 ,’A 1 ’,’B 1 


Note 

This command is only available for oscilloscope waveforms 
from an oscilloscope module in the same mainframe. 


WAVeform Subsystem 
4-18 





RANGe 


RANGe command/query 

The RANGe command specifies the full-scale range of the waveform 
display. This is equivalent to ten times the seconds per division setting on 
the display. The allowable values for RANGe are from 10 ns to 10 s. 

The RANGe query returns the current full-scale range. 

Command Syntax: :WAVeform:RANGe < revalue > 

where: 

< revalue > = 10E-9 s to 10 s (real number) 

Example: output ) 00 (,“:WAVEFORM: range 4E-8” 

Query Syntax: ;WAVeform;RANQe7 
Returned Format: [:WAVeform:RANGe] <r_value> <NL> 

Example: io dim setting$[ioo] 

20 OUTPUT XXX;":WA\/EFORM:RANGE? 

30 ENTER XXX;Setting$ 

40 PRINT Settings 
50 END 
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REMove command 

The REMove command removes all the waveforms from the display. 
Command Syntax: ;WAVeform;REMove 

Example: output XXX;":WAVEF0RM:REM0VP 
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RUNTil 


command/query 


The RUNTil (Run Until) command defines the stop criteria based on the 
time between the X and O markers when the trace mode is repetitive. 
When RUNTil is set to OFF, the analyzer will run until either the "STOP” 
touchscreen field is touched or the STOP command is sent. Run until the 
time between X and O marker options are: 

• Less Than (LT) a specified time value 

• Greater Than (GT) a specified time value 

• IN the RANGE between two time values 

• OUT of the RANGE of the two time values 


The end points for INRange and OUTRange must not be the same value. 
The RUOTil query returns the current value. 


Comnriand Syntax: :WAVeform:RUNril {0FF| LT, < value > | GT, < value > I INRange, < value > ,< value > | 

OUTRange, < value > ,< value > }" 

where: 

<value > = -53.5E3 s to +53.5E3 s (real number) 

Examples: output XXX;-: waveform: RUNTIL off 

OUTPUT XXX;":WAV:RUNT LT,10E-9" 

OUTPUT XXX;":WAVEFORM:RUNTIL GT,10E-9" 

OUTPUT XXX;":WAVEFORM:RUNTIL INRANGE, 10E-9,20E-9" 

OUTPUT XXX;":WAV:RUNT OUTRANGE, 10E-9,20E-9" 
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RUNTil 


Query Syntax: :WAVeform:RUNfTii7 

Returned Format: [:WAVeform:RUNTil] {OFF | LT, <value > IGT, < value > | INRange, <value > ,< value > | 

OUTRange, < value > ,< value >} 


Example: 10 dim Setting$[100] 

20 OUTPUT XXX;*:WAVEFORM:RUNTIL?" 
30 ENTER XXX;Setting$ 

40 PRINT Settings 
50 END 
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SPERiod query 


The SPERiod query returns the sample period of the last run. 
Query Syntax: WAVeform:SPERiod? 

Returned Format: [:WAVeform:SPERiocl] <tlme_value> <NL> 
where: 

< time_value > :; = 1E-9 s to 1.6E-3 s (real number) 

Example: io dim vaiue$[ioo] 

20 OUTPUT XXX;-:WAVEFORM:SPERIOD?“ 

30 ENTER XXX;Value$ 

40 PRINT Values 
50 END 
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TAVerage 

TAVerage query 

The TAVerage query returns the value of the average time between the X 
and O markers. If there is no valid data, the query returns 9.9E37. 

Query Syntax: :WAVeform:TAVerage? 

Returned Format: [-.WAVetorm-.TAVerage] <value><NL> 
where: 

< value > * -13.1072 s to +13.1072 s (real number) 

Example: io dim vaiue$[ioo] 

20 OUTPUT XXX;“;WAVEFORM:TAVERAGE?" 

30 ENTER XXX;Value$ 

40 PRINT Values 
50 END 
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TMAXimum 


query 


The TMAXimum query returns the value of the maximum time between 
the X and O markers. If there is no valid data, the query returns 9.9E37. 

Query Syntax: :WAVeform;TMAXimum7 
Returned Format; [.WAVeformTMAXimum] <value > < NL> 
where: 


<value > B -13.1072 s to -(■ 13.1072 s (real number) 


Example: 10 dim Max_value$I100] 

20 OUTPUT XXX.-:WAVEFORM:TMAXIMUM?" 
30 ENTER XXX;Max_value$ 

40 PRINT Max_value$ 

50 END 
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TMINimum 


query 


The TMINimum query returns the value of the minimum time between 
the X and O markers. If there is no valid data, the query returns 9.9E37. 

Query Syntax: :WAVeform;TMINimum7 
Returned Format: [:WAVefotm;TMINimum] <value>< nl> 

where: 

< value > :: = -13.1072 s to +13.1072 s (real number) 

Example: 10 dim Min_value$[100] 

20 OUTPUT X>0<;":WAVEFORM:TMINIMUM7" 

30 ENTER XXX;Min_value$ 

40 PRINT Min_value$ 

50 END 
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VRUNs 


query 


The VRUNs query returns the total number of runs and the number of 
valid runs made. Valid runs are those where the pattern search for both 
the X and O markers was successful, resulting in valid delta time 
measurements. 

Query Syntax: :\A^AVeform:VRUNs? 

Returned Format: [:WAVeform:VRUN s] <total_runs>,<valid_runs><NL> 


where: 

<total_runs> :: = positive integer (integer) 
<valld_runs> :: = positive Integer (Integer) 


Example: io dim Runs$[ioo] 

20 OUTPUT XXX;":WAVEFORM:VRUNS?" 
30 ENTER XXX; Runs$ 

40 PRINT Runs$ 

50 END 
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XCONdition command/query 

The XCONditioa command specifies whether the marker is to be placed 
on the entry or exit point of the pattern when you are in the PATTem 
marker mode. 

The XCONdition query returns the current setting. 

Command Syntax: ;WAVeform;XCONdition {ENTeringlEXITing} 

Example: output XXX“:WA\/EFORM:XCONDmON EXITING" 

Query Syntax: :WAVeform;XCONdition7 

Returned Format: [:WAVeform:XCONdition] {ENTering | EXITing} 

Example: 10 dim X_setting$[100] 

20 OUTPUT XXX":WA\/EFORM:XCONDITION?" 

30 ENTER XXXX_setting$ 

40 PRINT X_8etHng$ 

50 END 
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XOTime query 

The XOTime query returns the time from the X marker to the O marker. 

If the data is not valid, the query returns 9.9E37. 

Query Syntax; :WAVeform:XOTime? 

Returned Format: [:WAVeform:XOTime] <time_value> <NL> 
where: 

<time_value > = real number 

Example: io dim Time$[ioo] 

20 OUTPUT XXX;":WA\/EFORM;XOTIME?- 
30 ENTER XXX;Time$ 

40 PRINT rime$ 

50 END 
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XPATtern command/query 

The XPATtern command specifies a search pattern for the X marker 
which is then used with the XSEarch criteria and XCONdition for placing 
the marker on the pattern. The first parameter specifies the label and the 
second parameter specifies the search pattern for the label. Since each 
command deals with only one label, a specification over multiple labels 
requires multiple commands. 

Each label can contain up to 32 bits with a range between 0 and 
FFFFFFFFh (hexadecimal). Since the search pattern for the label can 
also contain don’t cares (X) and be represented in several bases, the 
pattern specification parameter for the label is handled as a string. 

In the PATTem marker mode, the XPATtern query returns the pattern 
specification for a given label. In the TIME marker mode, the query 
returns the pattern under the X marker for a given label. If the X marker 
is not on valid data, don’t cares (Xs) are returned. 

Command Syntax: :WAVeform:XPATtern <iabei_name>,<pattern> 


where: 

< label_name > ^ string of up to 6 alphanumeric characters 

< pattern > = string in one of the foiiowing forms: 

’•#801X" for binary 
"#001234567X* for octal 
''#H0123456789ABCDEFX'' for hexadecimal 
"0123456789" for decimal 
(don't cares "X" not allowed in decimal) 


Example: output XXX;":WAVEF0RM:XPATTERN *A*,’#B01001XX01 1 ’" 
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XPATtern 


Query Syntax: rWAVeformiXPATtern? <label_name> 


Returned Format: [:WAVeform:XPATtern] <label_name>,<pattern><NL> 


Example; 10 dim Pattern$[1CX)] 

20 OUTPUT XXX; ••:WAVEFORM:XPATTERN? ‘A’" 
30 ENTER XXX; Patterns 
40 PRINT Patterns 
50 END 
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command/query 


XSEarch 

XSEarch 


The XSEarch command specifies the search criteria for the X marker 
which is then used with the associated XPATtem specification and the 
XCONdition for placing markers on patterns. The first parameter for this 
command determines which occurrence of the XPATtern specification^ 
relative to the trigger, the marker actually searches for. An occurrence of 
0 (zero) places a marker on the selected starting point (trigger). The 
second parameter is optional since the X marker pattern is always 
referenced from the trigger point. The XSEarch query returns the search 
criteria for the X marker. 

Command Syntax: :WAVeform:OSEarch < occurrence >[,TRIGger] 

where: 

< occurrence > = -8192 to + 8192 finteger) 


Example: output XXX;":WAVEF0RM:XSEARCH 5 ,TRIGGER” 


Query Syntax: :WAVeform:XSEarch? 


Returned Format: [:WAVeform:XSEarch] <occurrence>JRIGger<NL> 


Example: 10 dim X.setting$[100] 

20 OUTPUT XXX;“:WAVEFORM:XSEARCH?" 
30 ENTER XXX;X^setting$ 

40 PRINT X_setting$ 

50 END 
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XTIMe command/query 

The XTIMe command places the X marker at a specified position in time 
when the marker mode is TIME. 

The XTIMe query returns the current position of the X marker. If there 
is no valid data, 9.9E37 is returned. 

Command Syntax: :WAVeform:XTIMe <time> 

where: 

<time > :: = -13.0 s to +53.5E3 s (real number) 

Example: output XXX;-:WAVEF0RM:XTIME 540ns" 

Query Syntax: :WAVeform:XTIMe? 

Returned Format: [: WAVeformixriMe] <time>< nl> 

Example: io dim x_vaiue$[ioo] 

20 OUTPUT XXX;":WAVEFORM:XTIME?" 

30 ENTER XXX;X^value$ 

40 PRINT X_value$ 

50 END 
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SYMBol Subsystem 



Introduction The SYMBol subsystem contains the commands that allow you to define 

symbols on the controller and download them to the HP 16515A/16516A 
1 GHz Timing Analyzer module. 



Figure 5-L SYMBol Subsystem Syntax Diagram 
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< label_name > = string of up to 6 alphanumeric characters 

< syinbol_name > = string of up to 16 alphanumeric characters 

< pattern value > = string of one of the following forms: 
''#B01X...~for binary 

''*Q01234567X.. "for octal 
"*H0123456789ABCDEFX... "for hexadecimal 
"0123456789..." for decimal 
(don’t cares "X" not allowed in decimal) 

< start_value > = string of one of the following forms: 

"*B01.Z" for binary 

"*Q01234567.. "for octal 
"#H0123456789ABCDEF... "for hexadecimal 
"0123456789... "for decimal 
(don’t cares "X" not allowed in decimal) 

<stop_vaIue> = string of one of the following forms: 

"#B01..." for binary 

"#Q01234567.. "for octal 

"#H0123456789ABCDEF... "for hexadecimal 

"0123456789... "for decimal 

(don’t cares "X" not allowed in decimal) 

<widtb_value> = integer form 1 to 16 

Figure 5-1. SYMBol Subsystem Syntax Diagram (Continued) 
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BASE 


command 


Command Syntax: 

where: 

< label_name > 

< base_value > 

Example: 


The BASE command sets the base in which symbols for the specified label 
will be displayed in the symbol menu. It also specifies the base in which 
the symbol offsets are displayed when symbols are used. 

Note 

BINary is not available for labels with more than 20 bits 
assigned. In this case the base will default to HEXadecimal, 


:SYMBol:BASE < label_name >, < base_value > 


:: = string of up to 6 alphanumeric characters 

::= {BINary | HEXadecimal | OCTal | DECimal | ASCII} 

OUTPUT XXX;":SYMBol:BASE ’DATA’, HEXadecimal" 
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PATTern 


command 


Command Syntax: 

where: 

< label__name > 
<symbol_name> 
< pattern_value > 

Example: 


The PATTern command allows you to create a pattern symbol for the 
specified label The pattern may contain ’’don’t cares” in the form of Xs. 

iSYMBol: PATTern < label_name >, < symbol_name >, < pattern_value > 


:: = string of up to 6 alphanumeric characters 
:: = string of up to 16 alphanumeric characters 
:: = string of one of the following forms: 
"#B01X" for binary 
••#Q01234567X“ for octal 
"#H0123456789ABCDEFX" for hexadecimal 
"0123456789" for decimal 
(dont cares "X" not allowed in decimal) 


OUTPUT XXX;":SYMBol:PATTern ’STAT, ’MEM_RD’,’#H01XX’" 
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RANGe 


command 


Command Syntax: 


where: 

< label_name > 
<symbol_name> 

< start_value > 


<stop_value> 


Example: 


The RANGe command allows you to create a range symbol containing a 
start value and a stop value for the specified label. 

Note 

Don^t cares ’X’ are not allowed in range symbols. 


:SYMBol:RANGe < label_name >, < symboI_name >, 
< start_value >, < stop_value > 


== string of up to 6 alphanumeric characters 
:: = string of up to 16 alphanumeric characters 
:: = string of one of the following forms: 
“#B0rfor binary 
"#001234567" for octal 
"#H0123456789ABCDEPfor hexadecimal 
"0123456789" for decimal 
(don’t cares "X" not allowed in decimal) 

:: = string of one of the following forms: 
"#B01"for binary 
"#001234567" for octal 
"#H0123456789ABCDEP for hexadecimal 
"0123456789" for decimal 
(don't cares "X" not allowed in decimal) 


OUTPUT XXX;":SYMBol:RANGe ’STAT’. ’IO.ACCESS’,’#HOOOO’;#HOOOF" 
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REMove 


command 


The REMove command deletes all of the current symbols. 
Command Syntax: :SymboI;REM ove 

Example: output XXX:":SYMBol:REMove" 
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WIDTh 


command 


Command Syntax: 

where: 

< labe!_name > 
<width_value > 

Example: 


The WIDTh command specifies the width (number of characters) in 
which the symbol names will be displayed when symbols are used. 

Note 

The WIDTh command does not affect the displayed length of the 
symbol offset value. 


:SYMBol:WIDTh < label_name >, < width_value > 


:: = string of up to 6 alphanumeric characters 
integer from 1 to 16 


OUTPUT XXXi^SYMBohWIDTh ’DATA’,9 - 
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DATA and SETup Commands A 



Introduction The DATA and SETup commands are SYSTem subsystem commands 

that allow you to send and receive instrument configuration and acquired 
data to and from a controller in block form. These commands allow you 
to save an entire block of data for processing in the controller, or for later 
analysis in the timing analyzer. This appendix explains how to use these 
commands. 

The block data for the DATA command and query is broken down into 
bytes and byte positions. This is intended primarily for processing of data 
in the controller. 


Note 

Do not change the block data in the controller if you intend to 
process the block data later in the timing analyzer. Changes 
made to block data in the controller may cause unpredictable 
results in the timing analyzer. 
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SYSTemiDATA 


SYSTem:DATA command/query 

The SYSTem:DATA command transmits the data part of the setup 
configuration for the selected module (1 GHz timing analyzer). This is 
transmitted in block data format and contains the contents of the 
acquisition buffer, including all measurement results. The 
SYSTemtDATA query returns the current contents of the acquisition 
buffer to the controller. 

Note 

When you reload data in the analyzer with the SYSTem:DATA 
command, make sure the exact analyzer configuration that was 
present when data was sent to the controller is still present To 
ensure the same configuration is still present, save the 
configuration with the SYSTem:SETup command and reload 
the configuration in the analyzer before you reload the data. 


Command Syntax: :SYSTem:DATA < block data in # format > 

Query Syntax: -.SYSTem.DATA? 

Returned Format: [:SYSTem:DATA] <block data In # format> <NL> 
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SYSTem:DATA 


Definition of 
Block Data 


Block data in the # format is made up of a block length specifier and a 
variable number of sections. 


<block length specifier> <section 1 > <section 2>...<section N> 


The block length specifier is defined as follows: 
#8 < length > 


where: 

< length > = the total length of all sections in byte format (must be represented with 8 digits) 


For example, if the total length of the block (all the sections) is 144 bytes, 
the block length specifier would be ”#800000144” since the length must be 
represented with 8 digits. 

Sections consist of a section header followed by the section data as follows: 
< section header > < section data> 


where: 

section header > = 10 bytes for the section name 

1 byte reserved (always 0) 

1 byte for the module ID code (1 for 1 GHz timing) 
4 bytes for the length of the section data in bytes 


The section data format varies for each section and may be any length. 

Note 

The total length of a section is 16 (for the section header) plus 
the length of the section data. Thus, when calculating the length 
of a block of configuration data, care should he taken to not 
forget to add the length of the section headers. 
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HP-IB Example: 10 dim Block$[32000] iailocate enough memory for block data 

20 DIM Speclfier$[2] 

30 OUTPUT XXX;'‘:EOI ON" 

40 OUTPUT XXX;":SYSTEM:HEADOFP 

50 OUTPUT XXX;":SELECT 4" Iselect module 

60 OUTPUT XXX;":SYSTEM:DATA?" Isend data query 

70 ENTER XXX USING "#,2A"; Specifier$ Iread in #8 

80 ENTER XXX USING "#,8D";Blocklength Iread in biock length 

90 ENTER XXX USING "-K";Block$ Iread in data 

100 END 

Data Command The SYSTem:DATA cx)minand for the HP 16515A/16A 1 GHz Timing 
Configuration Analyzer consists of the following section. Numbers are listed in the left 

hand column to specify the byte in the data block that the following value 
starts in. 

16 bytes - Section Header 

1 10 bytes - section name, "DATA ” (six trailing spaces) 

11 1 byte - reserved (always 0) 

12 1 byte - module ID (1 for HP 16515A/16A) 

13 4 bytes - length of section data in bytes 

(8192 * 2) + 24 for HP 16515A 
(8192 * 4) + 24 for HP 16515A/16516A 

24 bytes - Preamble Information 

17 2 bytes - how many pods are contained in the stored data. 

19 2 bytes - index of the leftmost on-screen sample (72 to 572). 

21 4 bytes - reserved 
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25 2 bytes - the pixel location of the leftmost sample (-1 to + 8191). 

This returns -1 if the waveform is off screen to the right. 

27 4 bytes - reserved 

31 4 bytes - index of the sample that is the trigger point. 

35 2 bytes - index of the sample period (see table A-1) 

Table A-2. Index Values for Sample Period 


Index 

Sample Period 

1 

Index 

Sample Period 

0 

1 ns 


10 

1.6 )xs 

1 

2 ns 


11 

3.2 )xs 

2 

4ns 


12 

8 fJLS 

3 

8ns 


13 

16 jjis 

4 

16 ns 


14 

32 |xs 

5 

32 ns 


15 

80 jxs 

6 

80 ns 


16 

160 |xs 

7 

160 ns 


17 

320 |jls 

8 

320 ns 


18 

800 jxs 

9 

800 ns 


19 

1.6 ms 


37 1 byte -1 if acquisition is valid, 0 if acquisition is not valid 


38 1 byte - reserved 

39 2 bytes - number of samples in the acquisition (always 8192) 
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SYSTem-.DATA 


40 8192 bytes - data for pod 2 of the HP 16515A 

8232 8192 bytes - data for pod 1 of the HP 16515A 

16424 8192 bytes - data for pod 2 of the HP 16516A (if an HP 16516A expansion 

card is installed) 

24616 8192 bytes - data for pod 1 of the HP 16516A (if an HP 16516A expansion 

card is installed) 

Note 

Each byte of the 8192 bytes for each pod represents one sample, 
with channel 7 the most significant bit and channel 0 the least 
significant bit 
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SYSTemrSETup 


SYSTem:SETup 


command/query 


The SYSTem:SETup command configures the selected module (1 GHz 
Timing Analyzer) as defined by the block data sent by the controller. The 
SYSTemrSETup query returns a block of data that contains the current 
configuration for the selected module to the controller. 

Command Syntax: :SYSTem:SETup < block data in # format> 

Query Syntax: :SYSTem:SETup? 

Returned Format: [:SYSTem:SETup] <block data in # format> <NL> 


Definition of 
Block Data 


Block data in the # format is made up of a block length specifier and a 
variable number of sections. 


< block length specifier > < section 1 > < section 2> 

The block length specifier is defined as follows: 
#8<iength> 


where: 

< length > = the total length of all sections in byte format (must be represented with 8 digits) 
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SYSTem:SETup 


For example, if the total length of the block (all the sections) is 144 bytes, 
the block length specifier would be ’’#800000144'’ since the length must be 
represented with 8 digits. 

Sections consist of a section header followed by the section data as follows: 


< section header > < section data> 

where: 

< section header > :: = 10 bytes for the section name 

1 byte reserved (always 0) 

1 byte for the module ID code (1 for 1 GHz timing) 
4 bytes for the length of the section data in bytes 


The section data format varies for each section and may be any length. 


Note 

The total lengfh of a section is 16 (for the section header) plus 
the length of the section data. Thus, when calculating the length 
of a block of configuration data, care should he taken to not 
forget to add the lengfh of the section headers. 


HP-IB Example: 10 dim Biock$[32000] lallocate enough memory for block data 

20 DIM Specifier$[2] 

30 OUTPUT XXX;": EOl ON" 

40 OUTPUT XXX;":SYSTEM:HEAD OFP 

60 OUTPUT XXX;":SELECT 4" Iselect module 

60 OUTPUT XXX;";SYSTEM:SETUP?" Isend setup query 

70 ENTER XXX USING "#,2A";Specifiers Iread in #8 

80 ENTER XXX USING "#,8D";Blocklength Iread in block length 

90 ENTER XXX USING "-K";Biock$ Iread In data 

100 END 
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